<!DOCTYPE html>
<html lang="en" xml:th="http://www.thymeleaf.org">
<head>
    <meta charset="UTF-8">
    <title>签到任务管理</title>
    <link rel="stylesheet" href="/layui/css/layui.css">
    <link rel="stylesheet" href="/css/custom.form.css">
</head>
<body>
<!--数据与分页-->
<div class="checkInTask_table_div">
    <!--多条件查询-->
    <div id="searchParam">
        <div class="layui-form-item">
            <div class="layui-input-inline">
                <input type="text" id="name" class="layui-input" autocomplete="off" placeholder="请输入签到任务名">
            </div>
            <div class="layui-input-inline ">
                <button class="layui-btn" id="search">查询</button>
            </div>
        </div>
    </div>
    <!--显示数据的表格-->
    <table class="layui-hide" id="checkInTask_table" lay-filter="checkInTask_table"></table>
    <!--分页相关 View-->
    <div id="laypage" class="layui-laypage-btn"></div>
</div>


<!-- 新增编辑签到任务View-->
<div class="panel panel-default operation_checkInTask" hidden>
    <div class="panel-heading title"></div>
    <div class="layui-card-body">
        <form class="layui-form " action="" lay-filter="deptInfo" style="width: 700px;margin-top: 10px">
            <input name="id" hidden/>
            <div class="layui-form-item">
                <label class="layui-form-label">签到任务名</label>
                <div class="layui-input-block">
                    <input type="text" name="name" placeholder="签到任务名" autocomplete="off"
                           class="layui-input">
                </div>
            </div>
            <div class="layui-form-item">
                <label class="layui-form-label">签到课程</label>
                <div class="layui-input-block">
                    <div id="courseSelect"></div>
                </div>
            </div>
            <div class="layui-form-item">
                <label class="layui-form-label">签到时间</label>
                <div class="layui-input-inline">
                    <input type="text" class="layui-input" id="date" name="checkInTime" placeholder="yyyy-MM-dd">
                </div>
            </div>

            <div class="layui-form-item">
                <div class="layui-input-block">
                    <button type="submit" class="layui-btn" lay-submit="" lay-filter="submit">保存
                    </button>
                    <button class="layui-btn layui-btn-primary" id="btn_cancel">返回</button>
                </div>
            </div>
        </form>
    </div>
</div>

</body>
<script src="/layui/layui.js"></script>
<script src="/js/core.util.js"></script>
<script src="/js/xm-select.js"></script>
<!--新增签到任务按钮、批量删除 按钮-->
<script type="text/html" id="toolbar">
    <div class="layui-btn-group">
        <!--shiro:hasPermission="sys:checkInTask:add"-->
        <button type="button" class="layui-btn" lay-event="addNewcheckInTask">
            <i class="layui-icon">&#xe608;</i> 新增签到任务
        </button>
    </div>
    <div class="layui-btn-group">
        <!--shiro:hasPermission="sys:checkInTask:delete"-->
        <button type="button" class="layui-btn" lay-event="batchDeleted">
            <i class="layui-icon">&#xe608;</i> 批量删除
        </button>
    </div>
</script>
<!--给签到任务赋予角色按钮-->
<!--shiro:hasPermission="sys:checkInTask:role:update"  shiro:hasPermission="sys:checkInTask:update" shiro:hasPermission="sys:checkInTask:delete" -->
<script type="text/html" id="tool">
    <a class="layui-btn layui-btn-xs" lay-event="edit">编辑</a>
    <a class="layui-btn layui-btn-xs" lay-event="show">查看签到情况</a>
    <a class="layui-btn layui-btn-danger layui-btn-xs" lay-event="del">删除</a>
</script>
<script>
    layui.use(['jquery', 'form', 'table', 'laypage', 'layer', 'element', 'laydate', 'tree', 'transfer', 'layedit', 'upload'], function () {
        var $ = layui.jquery;
        var form = layui.form;
        var table = layui.table;
        var laypage = layui.laypage
        var layer = layui.layer;
        var laydate = layui.laydate;


        var searchParam = {
            current: 1,
            size: 10,
            /*以下为多条件查询参数*/
            name: null
        }

        let checkInTaskSelect = xmSelect.render({
            el: '#courseSelect',
            name: "courseId",
            radio: true,
            data: []
        });

        CoreUtil.sendAjax("/study/course/teacher", null, function (res) {
            let data = res.map(course => ({
                name: course.name,
                value: course.id
            }))
            checkInTaskSelect.update({data})
        }, "GET", false, function (res) {
            //用户列表接口无权限回调
            layer.msg("抱歉！您暂无获取用户列表的权限");
        });


        /**
         *  加载分页数据
         */
        function loadPageInfo() {
            CoreUtil.sendAjax("/study/checkInTask/page", searchParam, function (res) {
                //初始化分页器
                laypageTable(res.total, searchParam.current);
                //初始化渲染数据
                loadTable(res.records);
                if (res.records != null) {
                    loadTable(res.records);
                }
            }, "GET", false, function (res) {
                //用户列表接口无权限回调
                layer.msg("抱歉！您暂无获取用户列表的权限");
                var noAuthorityData;
                noAuthorityData = [];
                loadTable(noAuthorityData);
            });
        }

        //渲染分页插件
        var laypageTable = function (count, currentPage) {
            laypage.render({
                elem: 'laypage'
                , count: count
                , limit: searchParam.size
                , layout: ['count', 'prev', 'page', 'next', 'limit', 'refresh', 'skip']
                , curr: location.hash.replace('#!currentPage=', '')     //获取起始页
                , hash: 'currentPage'                                   //自定义hash值
                , jump: function (obj, first) {
                    if (!first) {
                        searchParam.current = obj.curr;
                        searchParam.size = obj.limit;
                        loadPageInfo();
                    }
                }
            });
        };
        //渲染table
        var loadTable = function (data) {
            //展示已知数据
            table.render({
                elem: '#checkInTask_table'
                // 这个 data 为数组数据，直接 放到 data 上即可。
                , data: data
                , even: true
                , limit: data.length
                , limits: [10, 20, 30, 40, 50]
                , toolbar: '#toolbar'
                , cols: [
                    [
                        {type: 'checkbox', fixed: 'left'},
                        {field: 'id', title: 'ID', width: 300, sort: true},
                        {field: 'name', title: '签到任务名', width: 230},
                        {field: 'teacherName', title: '老师名', width: 250},
                        {field: 'introduce', title: '简介', width: 250},
                        {width: 400, toolbar: "#tool", title: '操作'}
                    ]
                ]
            });
        };
        loadPageInfo();

        //点击新增事件， 表头工具栏事件
        table.on('toolbar(checkInTask_table)', function (obj) {
            switch (obj.event) {
                case 'addNewcheckInTask':
                    $(".title").html("新增签到任务");
                    $(".checkInTask_table_div").hide();
                    $(".operation_checkInTask").show();
                    // 清除资料列表
                    $(".operation_checkInTask input[name=id]").val("");
                    $(".operation_checkInTask input[name=teacherId]").val("");
                    $(".operation_checkInTask input[name=introduce]").val("");
                    $(".operation_checkInTask input[name=name]").val("");
                    // 渲染时间
                    laydate.render({
                        elem: '#date'
                        , position: 'static'
                    });
                    form.render(); //更新全部
                    break;
                case 'batchDeleted':
                    var checkStatus = table.checkStatus(obj.config.id);
                    var data = checkStatus.data;
                    if (data.length === 0) {
                        layer.msg("请选择要批量删除的签到任务");
                    } else {
                        var checkInTaskIds = [];
                        $(data).each(function (index, item) {
                            checkInTaskIds.push(item.id);
                        });
                        tipDialog(checkInTaskIds, "选中的");
                    }
                    break;
            }
        });

        //编辑或新增的界面取消事件
        $("#btn_cancel").click(function () {
            //显示表格
            $(".checkInTask_table_div").show();
            //隐藏编辑窗口
            $(".operation_checkInTask").hide();
            //可以防止在表单事件操作后自动刷新
            return false;
        });

        //监听提交 新增和编辑  保存按钮
        form.on('submit(submit)', function (data) {
            //新增
            if (data.field.id === undefined || data.field.id === null || data.field.id === "") {
                CoreUtil.sendAjax("/study/checkInTask", JSON.stringify({...data.field}), function (res) {
                    //显示表格
                    loadPageInfo();
                    $(".checkInTask_table_div").show();
                    //隐藏编辑窗口
                    $(".operation_checkInTask").hide();
                    // 刷新页面，但是不管事儿
                    $(".layui-laypage-btn").click();
                    // 渲染时间
                    laydate.render({
                        elem: '#date'
                        , position: 'static'
                    });
                }, "POST", false, function (res) {
                    //新增签到任务无权限提示
                    layer.msg("抱歉！您暂无新增签到任务的权限");
                });
                // 编辑
            } else {
                CoreUtil.sendAjax("/study/checkInTask", JSON.stringify({...data.field}), function (res) {
                    //显示表格
                    $(".checkInTask_table_div").show();
                    //隐藏编辑窗口
                    $(".operation_checkInTask").hide();
                    $(".layui-laypage-btn").click();
                }, "POST", false, function (res) {
                    //更新签到任务无权限提示
                    layer.msg("抱歉！您暂无编辑签到任务的权限");
                });
            }
            return false;
        });


        //执行查询
        $("#search").click(function () {
            searchParam.title = $("#name").val();
            searchParam.current = 1;
            loadPageInfo();
        });


        table.on('tool(checkInTask_table)', function (obj) {
            var data = obj.data;
            switch (obj.event) {
                case 'edit':
                    $(".checkInTask_table_div").hide();
                    $(".operation_checkInTask").show();
                    $(".title").html("编辑签到任务");
                    $(".operation_checkInTask input[name=id]").val(data.id);
                    checkInTaskSelect.setValue([{name: data.courseName, value: data.courseId, selected: true}])
                    $(".operation_checkInTask input[name=teacherId]").val(data.teacherId);
                    $(".operation_checkInTask input[name=introduce]").val(data.introduce);
                    $(".operation_checkInTask input[name=name]").val(data.name);
                    form.render(); //更新全部
                    break;
                case 'show':
                    let open = layer.open({
                        title: "签到详情",
                        type: 2,
                        content: `/index/checkInTask/info?taskId=${data.id}`
                    });
                    layer.full(open);
                    break
                        ;

                case 'del':
                    var checkInTaskIds = [];
                    checkInTaskIds.push(data.id);
                    tipDialog(checkInTaskIds, data.name);
                    break;
            }
        });

        //删除前确认对话框
        var tipDialog = function (ids, name) {
            layer.open({
                content: '确定要删除' + name + "签到任务么?",
                yes: function (index, layero) {
                    layer.close(index); //如果设定了yes回调，需进行手工关闭
                    CoreUtil.sendAjax("/study/checkInTask", JSON.stringify(ids), function (res) {
                        layer.msg(res.message);
                        $(".layui-laypage-btn").click();
                    }, "DELETE", false, function (res) {
                        //删除签到任务无权限
                        layer.msg("抱歉！您暂无删除签到任务的权限");
                    });
                }
            });
        };
    });
</script>
</html>

